#### Student Honor Pledge:

All work submitted is completed by me directly without the use of any unauthorized resources or assistance

# **Final Exam**

Initials: \_\_\_\_\_ (April 21st @ 7:00 pm)

Presentation and clarity are very important! Show your procedure!

#### **PROBLEM 1 (12 PTS)**

• Complete the timing diagram of the following circuit.  $G = G_3G_2G_1G_0 = 0110$ ,  $Q = Q_3Q_2Q_1Q_0$ 



# PROBLEM 2 (10 PTS)

• Given the following circuit, complete the timing diagram. The LUT 6-to-6 implements the following function:  $OLUT = \lceil sqrt(ILUT) \rceil$ , where ILUT is a 6-bit unsigned number. For example  $ILUT = 41 (101001_2) \rightarrow OLUT = \lceil sqrt(41) \rceil = 7 (000111_2)$ 



#### **PROBLEM 3 (21 PTS)**

■ Two-pulse Detector: The timing diagram shows the behavior of the circuit. The FSM generates z=1 when it detects two pulses. Note how in this design, the output z is 1 as soon as the second  $1 \rightarrow 0$  transition is detected. Once the two pulses are detected, the FSM looks for a new pair of pulses. Assumption: For the circuit to detect a '1' or a '0' on x, this value needs to happen when a rising edge occurs.

z PSM
clock clock tick clock tick pulse! clock tick

Draw the State Diagram (any representation) of the given FSM (10 pts).



- The following FSM has 4 states, one input w and one output z. (11 pts)
  - ✓ The excitation equations are given by:

$$Q_1(t+1) \leftarrow Q_0(t)$$

$$Q_0(t+1) \leftarrow Q_1(t) \oplus \overline{w}$$

✓ The output equation is given by:  $z = Q_1(t) \oplus Q_0(t) \oplus w$ 



✓ Sketch the Finite State Machine circuit.



# PROBLEM 4 (11 PTS)

Sequence detector: This FSM has to generate z=1 when it detects the sequence 01011 or 11100. Once the sequence is detected, the circuit looks for a new sequence. Note that once we start detecting a sequence, we prioritize the sequence that we have over the other (e.g.: last sequence inside a dotted red rectangle is not considered).



✓ Draw the State Diagram (any representation) and provide the State Table of this circuit with input x and output z. Is this a Mealy or a Moore machine? Why?

### PROBLEM 5 (28 PTS)

- Draw the State Diagram (in ASM form) of the FSM whose VHDL description in shown below. (5 pts)
- Complete the Timing Diagram. (7 pts)
- Provide the State Table and the Excitation Table. Is it a <u>Mealy</u> or a <u>Moore FSM?</u> (6 pts).
- Provide the excitation equations and the Boolean output equations (simplify your circuit: K-maps or Quine-McCluskey).
- Sketch the circuit. (3 pts)

```
library ieee;
use ieee.std_logic_1164.all;
entity myfsm is
   port ( clk, resetn: in std_logic;
        r, p: in std_logic;
        x, w, z: out std_logic);
end myfsm;
```

```
architecture behavioral of myfsm is
  type state is (S1, S2, S3);
  signal y: state;
 Transitions: process (resetn, clk, r, p)
 begin
    if resetn = '0' then y <= S1;
     elsif (clk'event and clk = '1') then
       case y is
         when S1 =>
           if r = '1' then
              y <= S2;
              if p = 1' then y \le 33; else y \le 31; end if;
           end if;
         when S2 =>
           if p = '1' then y \le S1; else y \le S3; end if;
           if p = '1' then y \le S3; else y \le S2; end if;
       end case:
    end if;
 end process;
 Outputs: process (y, r, p)
 begin
     x <= 0'; w <= 0'; z <= 0';
     case y is
        when S1 \Rightarrow if r = 0' then
                       if p = '0' then
                         z <= '1';
                       end if;
                    end if;
        when S3 \Rightarrow if p = '0' then x \Leftarrow '1'; end if;
     end case;
 end process;
end behavioral;
```



# PROBLEM 6 (18 PTS)

- "Counting 0's" Circuit: It counts the number of bits in register A that has the value of '0'. The digital system is depicted below: FSM + Datapath. Example: For n=8: if A=00110010, then C=0101.  $\checkmark$  m-bit counter: If E=sclr=1, the count is initialized to zero. If E=1, sclr=0, the count is incremented by 1.
  - ✓ Parallel access shift register: If E = 1,  $s_{-}l = 1 \rightarrow \text{Load}$ . If E = 1,  $s_{-}l = 0 \rightarrow \text{Shift}$ .
- Complete the timing diagram where n = 8, m = 4. A is represented in hexadecimal format, while C is in binary format.



Instructor: Daniel Llamocca

Instructor: Daniel Llamocca

Instructor: Daniel Llamocca